<template>
  <div :class="classes">
    <template v-if="titlePlace === 'top'">
      <div class="x-text-box__title" v-if="title">{{ title }}</div>
      <div class="x-text-box__value"><span class="num" v-animated-number="value"></span><span class="unit" v-if="unit">{{ unit }}</span></div>
    </template>
    <template v-if="titlePlace === 'bottom'">
      <div class="x-text-box__value"><span class="num" v-animated-number="value"></span><span class="unit" v-if="unit">{{ unit }}</span></div>
      <div class="x-text-box__title" v-if="title">{{ title }}</div>
    </template>
  </div>
</template>

<script>
export default {
  name: 'TextBox',

  props: {
    // 标题
    title: {
      type: String
    },

    // 数值
    value: {
      type: Number
    },

    // 单位
    unit: {
      type: String
    },

    // 标题位置 [top|bottom]
    titlePlace: {
      type: String,
      default: 'top'
    },

    // 类型 [danger]
    type: {
      type: String
    },

    // 对齐方式 [left|right|center]
    align: {
      type: String,
      default: 'left'
    },

    // 尺寸 [small|normal|large|xlarge]
    size: {
      type: String
    }
  },

  computed: {
    classes () {
      let clsArr = ['x-text-box']
      const CLASS_OPTIONS = {
        'danger': 'x-text-box--danger',
        'left': 'x-text-box--left',
        'right': 'x-text-box--right',
        'center': 'x-text-box--center',
        'small': 'x-text-box--sm',
        'large': 'x-text-box--lg',
        'xlarge': 'x-text-box--xlg'
      }

      if (this.type) {
        clsArr.push(CLASS_OPTIONS[this.type])
      }

      if (this.align) {
        clsArr.push(CLASS_OPTIONS[this.align])
      }

      if (this.size) {
        clsArr.push(CLASS_OPTIONS[this.size])
      }

      return clsArr.join(' ')
    }
  }
}
</script>

<style lang="stylus">
@import '../../assets/stylus/common'

.x-text-box {
  .x-text-box__title {
    color: #99A1A8;
    font-size: 12px;
  }

  .x-text-box__value {
    color: #FFF;
    font-size: 22px;

    .unit {
      font-size: 12px;
      margin-left: 5px;
    }
  }
}

// 尺寸
.x-text-box--sm {
  .x-text-box__value {
    font-size: 16px;
  }
}
.x-text-box--lg {
  .x-text-box__value {
    font-size: 26px;

    .unit {
      font-size: 14px;
    }
  }
}
.x-text-box--xlg {
  .x-text-box__value {
    font-size: 45px;

    .unit {
      font-size: 30px;
    }
  }
}

// 类型
.x-text-box--danger {
  .x-text-box__value {
    color: red;
  }
}

// 对齐方式
.x-text-box--right {
  .x-text-box__title,
  .x-text-box__value {
    text-align: right;
  }
}
.x-text-box--center {
  .x-text-box__title,
  .x-text-box__value {
    text-align: center;
  }
}
</style>
